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ABSTRACT 



Aprogram guide system is provided that supports a program 
guide application and multiple non-guide applications. The 
program guide system has a program guide application 
interface that allows the non-guide applications to use both 
device resources and program guide resources. The appli- 
cation interface maintains a list of registered applications 
and directs control requests from various applications to the 
current primary application. The application interface also 
has a user interface input director that directs keystrokes and 
other user input commands to the appropriate application. If 
a keystroke for the program guide application is detected 
while a non-guide application is running, the program guide 
application is invoked. 

21 Claims, 9 Drawing Sheets 
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PROGRAM GUIDE APPLICATION 
INTERFACE SYSTEM 

This application claims the benefit of U.S. provisional 
patent application No. 60/058,073, filed Sep. 5, 1997. 

BACKGROUND OF THE INVENTION 

This invention relates to systems that support an interac- 
tive television program guide application and non-guide 
applications. More particularly, the invention relates to 
systems in which non-guide applications can use both device 
resources and program guide resources. 

Cable, satellite, and broadcast television systems provide 
viewers with a large number of television channels. Viewers 
have traditionally consulted printed television program 
schedules to determine the programs being broadcast at a 
particular time. More recently, interactive electronic televi- 
sion program guides have been developed that allow tele- 
vision program information to be displayed on a viewer's 
television. 

Interactive program guides are typically implemented on 
set-top boxes. Such program guides allow users to access 
television program listings in different display formats. For 
example, a user may desire to view a grid of program listings 
organized in a channel-ordered list. Alternatively, the user 
may desire to view program listings organized by time, by 
theme (movies, sports, etc.), or by title (i.e., alphabetically 
ordered). 

A user may also select a program for viewing or recording 
from the program guide. For example, the user may place a 
highlight region on top of a desired program listing and press 
a "record" button on a remote control. Pay programs may be 
ordered by placing the highlight region on a pay program 
listing and pressing an "order" button. Some program guides 
allow parents to block certain television programs based on 
criteria such as ratings information. 

It would be desirable if the set- top box on which the 
interactive program guide is implemented could be used to 
support other applications in addition to the program guide 
application. For example, the user of the set-top box might 
wish to use the set-top box to implement an Internet browser 
application, a video-on-demand application, an interactive 
promotional channel application, a shopping application, 
etc. However, previously known program guide systems 
have generally been designed to run only one application at 
a time. With these systems the currently running application 
typically has exclusive control of set-top box resources such 
the on-screen display, tuner, remote control interface, light- 
emitting diodes, communications channels, etc. This may 
lead to conflicts. For example, if a non-guide application is 
running when the program guide application would nor- 
mally have issued a reminder (e.g., for an upcoming tele- 
vision event), the user may not be able to receive the 
reminder. Moreover, the relatively high-level resources of 
the program guide application (such as parental control, 
program guide database access functions, etc.) have been 
unavailable to no n -guide applications. 

It is therefore an object of the present invention to provide 
an interactive television program guide system in which a 
program guide application and other applications may be 
implemented on the same set-top box and in which non- 
guide applications may use program guide resources. 

SUMMARY OF THE INVENTION 

This and other objects of the invention are accomplished 
in accordance with the principles of the present invention by 
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providing an interactive program guide system which sup- 
ports a program guide application and multiple non-guide 
applications. The system may be implemented on a set-top 
box or a comparable hardware platform. The program guide 

5 application runs on the set- top box to provide an interactive 
display of television program listings. A user may use the 
program guide to search for listings based on keywords, to 
order pay programs, to select a television program for 
recording, etc. The no n -guide applications that run on the 

io set-top box may include applications such as an Internet 
browser application, a video-on-demand application, an 
interactive promotional channel application, a shopping 
application, an electronic mail application, an audio -on- 
demand application, a banking application, a data services 

15 application, a wagering application, etc. 

The applications use set-top box resources such as a 
display resource, a user input interface resource, a tuner 
resource, a communications circuitry resource, a memory 
resource, etc. The program guide application has program 

20 guide resources such as a parental control resource, a 
graphics library resource, a pay program purchasing 
resource, a program guide database access resource, a sched- 
uling resource, a tuning resource, a menu resource, etc. The 
program guide resources are higher level resources than the 

25 device resources and are provided as part of the program 
guide. A program guide application interface allows the 
non -guide applications to use both the device resources and 
the program guide resources. 

In addition, the program guide application interface 

30 allows applications to register and maintains a list of such 
registered applications. A control request processor within 
the program guide application interface directs control 
requests and suspend requests from the applications to the 
primary application that is running on the set-top box. The 

35 primary application processes the control requests and sus- 
pend requests and determines whether to relinquish control 
to a requesting application or whether to suspend operation 
of the primary application. 

^ The program guide application interface intercepts key- 
strokes and other user input and determines to which appli- 
cation such user input should be sent. During registration, 
applications may provide the program guide application 
interface with key lists that identify the keys that application 

45 desires to use when it is the active application and when it 
is a background application. 

The program guide application interface resolves conflicts 
between various applications as the applications contend for 
shared resources. For example, the application interface may 

5Q coordinate requests from different applications to use the 
same key or to simultaneously use the display. In resolving 
such conflicts, the application interface may take account of 
which resources may not be shared, which resources may be 
shared without restriction, and which resources may be 

55 shared only with the guidance of the application interface. 
Further features of the invention, its nature and various 
advantages will be more apparent from the accompanying 
drawings and the following detailed description of the 
preferred embodiments. 

60 BRIEF DESCRIPTION OF THE DRAWINGS 

FIG. 1 is a schematic diagram of a system in accordance 
with the present invention. 

FIG. 2 is a schematic diagram of illustrative user tele vi- 
es sion equipment in accordance with the present invention. 
FIG. 3 is a schematic diagram showing the relationship 
between a program guide application interface, program 
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guide application, non-guide applications, and various 
device resources in accordance with the present invention. 

FIG. 4a is a flow chart of illustrative steps involved in 
processing requests to use resources with the program guide 
application interface in accordance with the present inven- 
tion. 

FIG. 46 is a flow chart of illustrative steps involved in 
processing multiple requests to utilize resources with the 
program guide application interface in accordance with the 
present invention. 

FIG. 5 is a flow chart of illustrative steps involved in 
registering applications with the program guide application 
interface and maintaining a list of registered applications in 
accordance with the present invention. 

FIG. 6a is a flow chart of illustrative steps involved in 
processing control requests with the program guide appli- 
cation interface in accordance with the present invention. 

FIG. 66 is a flow chart of illustrative steps involved in 
processing suspend operation requests with the program 
guide application interface in accordance with the present 
invention. 

FIG. 7 is a flow chart of illustrative steps involved in 
directing user input to the appropriate application with the 
program guide application interface of the present invention. 

DETAILED DESCRIPTION OF THE 
PREFERRED EMBODIMENTS 

An illustrative program guide system 10 in accordance 
with the present invention is shown in FIG. 1. Main facility 
12 provides data from program guide database 14 to tele- 
vision distribution facility 16 via communications link 18. 
Link 18 may be a satellite link, a telephone network link, a 
cable or fiber optic link, a microwave link, a combination 
such links, or any other suitable communications path. 
Television distribution facility 16 may be a cable system 
headend, a broadcast distribution facility, or a satellite 
television distribution facility. If desired, television distri- 
bution facility 16 may have the capability to support (either 
alone or in combination with additional facilities) services 
such as Internet access, home shopping, video-on-demand 
services, electronic mail applications, audio-on-demand 
applications, banking applications, data services 
applications, wagering applications, etc. For example, if 
video -on -demand services are desired, television distribu- 
tion facility 16 may contain a video or audio server. If home 
shopping services are to be provided, television distribution 
facility 16 may contain a home shopping database or may 
support communications to a home shopping service pro- 
vider. Internet access may be provided by a server within 
television distribution facility 16 or may be provided by 
facilitating communications with a separate Internet service 
provider. Banking, wagering, and data services may be 
provided using facilities separate from television distribu- 
tion facility 16. If desired, such separate facilities may be 
accessed through television distribution facility 16. 

The data transmitted by main facility 12 to television 
distribution facility 16 includes television program guide 
data such as program times, channels, titles, descriptions and 
other program listings information, and pay program pricing 
information, copy protection information, etc. If desired, 
some data may be provided using data sources at facilities 
other than main facility 12. For example, data for supporting 
a home shopping application may be provided using a 
separate data facility (not shown). 

Television distribution facility 16 distributes the program 
guide data and data for other services to multiple users via 
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communications paths 20. Program guide data may be 
distributed periodically (e.g., once per hour or once each 
week). Each user has user television equipment 22. User 
television equipment 22 typically contains a set-top box 24, 

5 a video cassette recorder 26, and a television 28. Set-top box 
24 may be controlled by a user input device 30 such as a 
remote control, wireless keyboard, mouse, trackball, etc. 

Set-top box 24 contains a microprocessor and other 
circuitry for executing instructions to provide the features of 

10 the present invention. For example, an interactive television 
program guide may be implemented on set-top box 24 by 
executing a suitable program guide application. Other appli- 
cations and a program guide application interface are also 
preferably implemented on set-top box 24. The applications 

15 and the program guide application interface may be imple- 
mented on user television equipment other than a set-top box 
if desired. However, the present invention will be illustrated 
with reference to a set-top box implementation for clarity. 
Communications paths 20 preferably have sufficient 

20 bandwidth to allow television distribution facility 16 to 
distribute scheduled television programming, video-on- 
demand services, and other video information to user equip- 
ment 22 in addition to program guide data and data for other 
services. If desired, program guide data and data for other 

25 services may be distributed by one or more distribution 
facilities that are similar to but separate from television 
distribution facility 16 using communications paths that are 
separate from communications paths 20. 

3Q Certain functions such as pay program purchasing may 
require user equipment 22 to transmit data to distribution 
facility 16 over communications paths 20. If desired, such 
data may be transmitted over telephone lines or other 
separate communications paths (not shown). Functions such 

35 as Internet services, home shopping services, etc. may also 
be provided using separate communications paths. 

Multiple television channels (analog, digital, or both 
analog and digital) may be provided to set-top box 24 via 
communications path 20. During normal television viewing, 

40 the user tunes set- top box 24 to a desired one of these 
channels. The signal for that television channel may then be 
provided at video output 32 as a radio-frequency (RF) signal 
on a predefined channel (e.g., channel 3 or 4) or as a 
demodulated video signal. The video signal at output 32 is 

45 received by videocassette recorder 26, so that the user may 
record programs. Program recording and other features may 
be controlled by set-top box 24 using control path 34. A 
typical control path 34 involves the use of an infrared 
transmitter coupled to the infrared receiver in videocassette 

50 recorder 26 that normally accepts commands from a remote 
control. Such a remote control or other suitable user input 
device 30 may be used to control set-top box 24, videocas- 
sette recorder 26, and television 28. 

Television 28 may receive RF or demodulated video 

55 signals from videocassette recorder 26 via path 36. The 
video signals on path 36 may either be generated by video- 
cassette recorder 26 when playing back a prerecorded vid- 
eocassette or may by passed through from set- top box 24. 
The video signals provided to television 28 may be real-time 

60 video signals such as a broadcast television program, a 
video -on-demand program, or video for a service with a 
real-time video component such as a promotional channel or 
home shopping service. The video signals may also contain 
information such as graphics and text to be displayed in 

65 addition to or in place of such real-time videos. 

As shown in FIG. 2, multiple input devices may be used 
with set-top box 24. For example, infrared remote control 
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30a may be used to control the interactive program guide. of images that may be displayed include program listings 

Infrared keyboard 306 may be used when browsing the grids, web pages, product lists, promotional information, 

Internet or to enter information for the program guide. etc. 

Pointing device 30c, which may be a mouse, trackball, FIG. 3 shows how the system of the present invention has 
touch-pad or other suitable pointing device, may be used 5 a program guide application interface 54 that supports a 
when browsing the Internet. Signals from infrared devices program guide application 56 and one or more non-guide 
may be received with infrared receiver 38. Other user input applications such as Internet browser application 58, video- 
devices may be coupled more directly to control circuitry 40. on-demand application 60, interactive promotional channel 
The input devices shown in FIG. 2 are illustrative. Any application 62, and shopping application 64. Other non- 
suitable type of input device may be used, including infrared 10 applications that may be supported include electronic 
pointing devices, other types of wireless devices, hardwired mail applications, audio-on-demand applications, banking 
remotes or keyboards, voice-recognition devices, etc. applications, data services applications, wagering 
o * . u u i_ applications, etc. Program guide application interface 54 
Set-top box 24 may contain one or more data ports such * t , r • i J , • « 
a . a<* r * . * • *u 1 i • ♦ u rnay be part ot program guide application 56 or may be 
as data port 42 for mterf acme with local equipment such as . . ■ ^ ™ -j 

i _ . . , , u i*i t\ ? * a<% ~ u k separate, as shown in rIG. 3. Program guide application 56 

a personal computer, printer or the like. Data port 42 may be 15 * * &\ & rv 

*-ui -*u ■* ui * i u provides the features oi an interactive program guide using 

compatible with any suitable communications protocol, such ^ ., . n „ r & & & 

the IEEE 1394 bus standard, the RS-232 bus standard, or the P ro f ar " 8^ «*™»"™? 68 For e ^P le - j> r °er am &™f 

USB (Universal Serial Bus) standard. application 68 may obtain program listings data previously 

_ , ' , . . r . stored in memory using database access resource 68a. 

Indicators 44 may be used to display certain information p r ^ data be dis 1 d usin various tem _ 

directly on set-top box 24. For example, numenc indicators ktes and dis { of hicg ^ resQurce 

may be used to display the current channel to which set-top m p ay ^ pr0 g rams - ma y^e T urchased using pay purchasing 

box 24 is tuned. Dedicated single -element indicators may be ^esouYc^Sc^Pmgra^ 

used to indicate that the power m the system is on or that a ^o-locl^pr^^ 

message has been received, etc. ^ Programs may be scheduled for recording and reminders for 

Infrared transmitter 46 may be used to transmit control certain programs may be set using scheduling resource 6Se. 

commands to the infrared receiver in videocassette recorder T^ingjrcsouj^^ 

26 (e.g., to direct videocassette recorder 26 to turn on and to to^ich-the -program^ 

record a television program that the user has selected from r5gforce r 68/' tune ^satisfy predefined r wentab c ontrol Tcritena 

the program guide). ^ (usinlpresc^^ 

Memory 48 may be used to store data and instructions for viewer' Fd^ 

execution by a microprocessor contained in control circuitry tuning^source 68/ may also be used to control the front- 

40. panel light-emitting diodes (LEDs) or other such display that 

Set-top box 24 also contains tuning, communications, and is used to display channel numbers and the like. Menu 

display circuitry 50. Circuitry 50 handles tuning functions 35 resource 68g may be used to display various items on 

such as receiving and demodulating analog and digital video program guide menu display screens. Other illustrative 

and audio streams. Circuitry 50 may also descramble pay program guide resources may be used to descramble certain 

channels and video-on-demand channels. If a program is programs, to receive and display e-mail, etc. 

copy protected and set-top box 24 receives proper Program guide application interface 54 allows non-guide 

authorization, circuitry 50 can remove the copy protection. 40 applications such as non-guide applications 58, 60, 62, and 

Parents may lock certain programs so that they cannot be 64 to use program guide resources 68 or to use device 

viewed by children. Circuitry 50 may block programs that resources 66 directly. For example, video-on-demand appli- 

have been locked by distorting the video and audio supplied cation 60 may display a list of program titles on television 

at output 32 or by preventing children from tuning to the 28 (FIG. 2) using on-screen and front panel display 

blocked programs. 45 resources 66a (i.e., the display circuitry portion of circuitry 

Circuitry 50 also handles various communications func- 50 of FIG. 2 and any associated set-top box software that 

tions. For example, downstream data such as program guide drives indicators 44 and television 28). Video-on-demand 

data from television distribution facility 16 (FIG. 1) may be application 60 may also display a list of program titles on 

supplied to set-top box 24 over an in-band, out-of-band, or television 28 using program guide graphics library resource 

vertical blanking interval link in communications path 20. 50 6Sb. Program guide graphics library resource 68b preferably 

Circuitry 50 provides such downstream data to control supports functions for drawing the types of displays used in 

circuitry 40. Circuitry 50 also handles upstream data such as program guides. Typical graphics library functions include 

pay program purchasing information that is supplied to functions for generating lists of television program titles, 

television distribution facility 16 (FIG. 1) over communi- program listings grids or tables, pay program ordering 

cations path 20. Additional communications functions may 55 screens, menus, etc. 

be provided using modem 52, which may be linked to Using graphics library resource 686 involves the use of 

television distribution facility 16 (FIG. 1) and other suitable display resource 66a because implementing the functions of 

data distribution and service provider facilities via the graphics library resource 68b involves the use of the cir- 

telephone network. If desired, a cable modem or other cuitry of display resource 66a. Nevertheless, using the 

high-speed data communications device may be used for eo functions of graphics library resource 68fc rather than using 

certain types of communications. display resource 66a directly conserves resources, because 

Circuitry 50 preferably allows various images to be the functions provided by graphics library resource 68b do 

displayed on television 28 via output 32 and path 36. not need to be duplicated by video -on-demand application 

Displayed images may include graphics, text, animations, 60. 

etc. Images may be displayed in place of video information 65 Another program guide resource that video-on-demand 

or may be displayed at the same time as video information application 60 may use is database access resource 68d. 

(e.g., by using circuitry 50 as an image overlayer). Examples Database access resource 68d is a program guide resource 
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that allows program guide application 56 to access program 
data (e.g., program titles, times, channels, ratings, summary 
information, etc.) that has been stored in memory. Although 
such data might be retrieved directly from memory using 
memory resource 66e, the database management functions 5 
of database access resource 68d help facilitate the orderly 
storage and retrieval of program data in memory. As a result, 
it is more efficient for video -on-demand application 60 to 
use database access resource 6Sd than to duplicate such 
functions within video -on-demand application 60. 10 

Some of the functions of video-on-demand application 60 
may be best provided using device resources 66. For 
example, when a user places an order for a video, the order 
may be transmitted via an upstream data path to a video 
server in television distribution facility 16. Such upstream 15 
transmissions can be accomplished using communications 
circuitry resource 66d. 

Another illustrative example involves Internet browser 
application 58, which primarily relies on direct use of device 
resources 66. Display functions may be provided using 20 
display resource 66a. Internet communications functions 
may be provided using communications circuitry resource 
66d (e.g., modem 52 of FIG. 2 and its associated software). 
Memory resource 66e may be used directly, because data- 
base access resource 6Sd is not required for Internet brows- 25 
ing. Internet browser application 58 can also use the user 
input interface resource 66b to support pointing device 30c 
(FIG. 2). If desired, a message light (one of indicators 44 of 
FIG. 2) may be turned on by Internet browser application 58 
whenever Internet e-mail is received. Supporting this func- 30 
tion may involve direct use of display resource 66a. 

Interactive promotional channel application 62 uses dif- 
ferent resources. For example, interactive promotional chan- 
nel application 62 may not use the message light function of 35 
display resource 66a. Interactive promotional channel appli- 
cation 62 may support use of a remote control (user input 
interface resource 66b). Tuner resource 66c may be used to 
tune to an appropriate promotional channel from among the 
various channels of video provided to set- top box 24 via path 
20 (FIG. 2). Program guide resources 68 that may be used 
by interactive promotional channel application 62 include 
pay purchasing resource 68c, database access resource 68d, 
and-graphics library resource 6Sb. Pay purchasing resource 
68c handles purchasing functions such as entering personal ^ 
identification numbers (PIN), confirming purchases, and 
issuing reminders when programs are about to begin. Data- 
base access resource 68d handles functions such as access- 
ing titles, broadcast times and program summaries. Graphics 
library resource 68b may be used to display banners and 5Q 
templates for program titles and program summary infor- 
mation. 

Shopping channel application 64 may use graphics library 
resource 686 to display product lists. Communications cir- 
cuitry resource 66d may be used to transmit product orders 55 
to an order processing facility. Various input devices may be 
supported using user input interface resource 66b, such as 
remote control 30a, keyboard 30&, and pointing device 30c. 

These examples are illustrative only. Various other suit- 
able applications may be used and such applications may use 60 
any suitable combinations of functions provided by program 
guide resources 68 and device resources 66. 

The process by which program guide application interface 
54 handles requests from the non -guide applications to use 
program guide resources 68 and device resources 66 is 65 
shown in FIG. 4a. At step 70, program guide application 
interface 54 receives and processes requests from applica- 
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tions to use resources (e.g., to use graphics library 68b or 
display 66a). If a request is made to use one of device 
resources 66, program guide application interface 54 directs 
the request to device resources 66 at step 72, so that the 
requesting application may use the requested device 
resource 66. If a request is made to use one of program guide 
resources 68, program guide application interface 54 directs 
the request to program guide resources 68 at step 74. At step 
76, the requesting application uses the device resources 66 
that are involved in the use of the requested program guide 
resources 68 (e.g., the requesting application uses display 
66a if a request was made to use graphics library 68b, which 
relies upon the use of display 66a). 

When more than one application makes resource requests 
(for device and/or program guide resources) at the same 
time, the program guide application interface coordinates 
the multiple requests so as to avoid contention between 
applications for the same resources, as shown in FIG. 46. At 
step 110, the program guide application interface receives 
multiple requests from different applications. For example, 
the program guide application interface may receive simul- 
taneous requests to use display resource 66a from a home 
shopping application and from the program guide. At step 
112, the program guide application interface coordinates the 
requests thereby resolving the conflicts between the various 
requesting applications. Any suitable technique may be used 
to resolve conflicts. For example, the program guide appli- 
cation interface may always favor the program guide over 
non-program guide applications. Another technique 
involves weighing the importance of the various requests. 
With this approach, each application may attach a weight to 
its requests indicating how urgently the requested resource 
is needed. Yet another technique for resolving conflicts 
between multiple applications that request resources at the 
same time involves using lists that set forth the resource 
requirements of the applications. For example, each appli- 
cation may submit to the application interface a predefined 
list of which keys (part of user input interface resource 66b) 
are desired when that application is active (i.e., an active key 
list) and a list of which keys are desired when the application 
is running in the background (i.e., a background key list). 
The application interface may take the contents of such lists 
into account when deciding how to resolve a conflict 
between two applications that are requesting use of the same 
remote control key or any other shared resource. In resolving 
conflicts, the application interface may take into account that 
certain resources may be shared, some resources may not be 
shared, and other resources may be shared, but only through 
the intervention of the application interface. An example of 
a resource that may be shared through the intervention of the 
application interface are the front-panel set-top box light- 
emitting diodes. At step 114, the program guide application 
interface directs resource requests to the device and program 
guide resources. 

In order to facilitate operation of the system of the present 
invention with multiple applications, program guide appli- 
cation interface 54 maintains a registered application list 78 
(FIG. 3) that allows interface 54 to keep track of which 
applications are loaded in set-top box 24 (FIG. 2) and how 
to communicate with them. 

The process by which program guide application interface 
54 maintains registered application list 78 is shown in FIG. 
5. An application registers by supplying a communications 
address and an identifier to program guide application 
interface 54. The communications address and identifier are 
received by program guide application interface 54 at steps 
80 and 82. At step 84, program guide application interface 
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54 updates registered application list 78 of FIG. 3 accord- 
ingly. At a later time, a registered application may be 
unregistered (step 85). 

The communications addresses in list 78 are used by 
program guide application interface 54 in sending messages 
(data or commands) to the various registered applications. 
Messages from the applications to program guide applica- 
tion interface 54 are tagged with appropriate identifiers. 
Program guide application interface 54 may identify which 
application provided a given message by comparing the 
identifier accompanying the received message to the iden- 
tifiers in list 78. 

Another function of program guide application interface 
54 involves processing control requests from various appli- 
cations (including the program guide application). For 
example, video -on-demand application 60 may request con- 
trol in order to turn on a message light or to display a 
message informing the user that the desired video selection 
is about to be delivered. If another application (e.g., shop- 
ping application 64) currently has primary control of set-top 
box 24 (FIG. 1), program guide application interface 54 
transfers the control request from video-on-demand appli- 
cation 60 to shopping application 64, which may then decide 
whether to relinquish control. 

Program guide application interface 54 contains control 
request processor 86 for handling control requests. Steps 
involved in processing control requests with control request 
processor 86 are shown in FIG. 6a. At step 88, control 
request processor 86 of program guide application interface 
54 receives a control request from a requesting application 
(e.g., video-on-demand application 60). At step 90, control 
request processor 86 determines which application is the 
current primary application and directs the control request to 
that application. At step 92, the primary application (e.g., 
shopping application 64) determines whether to relinquish 
control based on preset or dynamic priorities. If the primary 
application does not relinquish control to the requesting 
application at step 92, control returns to step 88. If the 
primary application does relinquish control at step 92, the 
requesting application takes primary control of the operation 
of set-top box 24 (FIG. 1) at step 94. 

The operation of control request processor 86 that is 
shown FIG. 6a is illustrative only. Other suitable arrange- 
ments for handling control requests may be used. For 
example, program guide application interface 54 may handle 
the determination of which application should maintain 
primary control of the system rather than the primary 
application. 

As shown in FIG. 6b, control request processor 86 may 
also handle requests to suspend the operation of the primary 
application, rather than simply to terminate its operation. At 
step 116, control request processor 86 of program guide 
application interface 54 receives a suspend request from a 
requesting application (e.g., video-on-demand application 
60). At step 118, control request processor 86 determines 
which application is the current primary application and 
directs the suspend request to that application. At step 120, 
the primary application (e.g., shopping application 64) 
determines whether to suspend its operation based on preset 
or dynamic priorities. If the primary application does not 
suspend its operation at step 120, control returns to step 116. 
If the primary application does suspend its operation at step 
120, the requesting application takes temporary control of 
the operation of set -top box 24 (FIG. 1) at step 122. The 
suspension of operation of the primary application may be 
terminated by a control request directing the requesting 
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application that is in temporary control to relinquish control. 
Alternatively, at step 124 the program guide application 
interface may receive an end suspension message and may 
direct the end suspension message to the primary application 

5 whose operation is being temporarily suspended. The pri- 
mary application may then resume control at step 126. If 
desired, control request processor 86 may handle both 
control requests to relinquish control (as shown in FIG. 6a) 
and suspend operation requests to suspend operation (as 

io shown in FIG. 6b). 

Another function of program guide application interface 
54 is to intercept input from the user interface (e.g., remote 
control 30a, infrared keyboard 30fc, pointing device 30cetc.) 
and to direct that input to the appropriate application running 

15 within set-top box 24. As shown in FIG. 3, program guide 
application interface 54 has user interface input director 96 
for directing keystrokes, remote control button presses, 
mouse clicks, etc. to applications 56, 58, 60, 62, and 64. The 
operation of user interface input director 96 is shown in FIG. 

20 7. At step 98, user interface input director 96 detects user 
input. At step 100, this user input is directed to the appro- 
priate application while conflicts between applications are 
resolved. In order to resolve conflicts that may occur when 
multiple applications request access to the same user input 

25 device (e.g., remote control keys), each application may 
submit to the application interface a predefined list of which 
keys are desired when that application is active (an active 
key list) and a list of which keys are desired when the 
application is running in the background (a background key 

30 list). Applications may submit such key lists to the applica- 
tion interface at device registration (FIG. 5) or dynamically, 
at any suitable time during the operation of the system. 
Applications may assign priorities to their key requests by 
adding priority entries to the key lists if desired. The 

35 application interface may take the contents of such lists into 
account when deciding how to resolve a conflict between 
two applications that are requesting use of the same remote 
control key. 

The foregoing is merely illustrative of the principles of 
40 this invention and various modifications can be made by 
those skilled in the art without departing from the scope and 
spirit of the invention. 

What is claimed is: 

1. A system in which an interactive television program 
45 guide and non-guide applications are implemented on user 

television equipment, comprising: 

a plurality of device resources within the user television 
equipment; 

50 an interactive television program guide comprising a 
plurality of program guide resources; and 
program guide application interface means for allowing 
the non-guide applications to use both the program 
guide resources and the device resources, wherein the 

55 non-guide applications access the program guide 
resources and the device resources directly through the 
program guide application interface means. 

2. The system defined in claim 1 wherein the program 
guide application interface means further comprises means 

60 for receiving and processing requests to use resources from 
the non-guide applications. 

3. The system defined in claim 1 wherein the program 
guide application interface means further comprises means 
for directing requests to use resources that are received from 

65 the no n- guide applications to the device resources. 

4. The system defined in claim 1 wherein the program 
guide application interface means further comprises means 
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for directing requests to use resources that are received from 
the non-guide applications to the program guide resources. 

5. The system defined in claim 1 wherein the device 
resources further comprise at least one device resource 
selected from the group consisting of: an on-screen display 5 
resource, a front-panel display resource, a user input inter- 
face resource, a tuner resource, a communications circuitry 
resource, and a memory resource. 

6. The system defined in claim 1 wherein at least one of 
the program guide resources comprises a tuning resource, to 

7. The system defined in claim 1 wherein at least one of 
the program guide resources comprises a parental control 
resource. 

8. Hie system defined in claim 1 wherein at least one of 
the program guide resources comprises a graphics library 15 
resource. 

9. The system defined in claim 1 wherein at least one of 
the program guide resources comprises a pay program 
purchasing resource. 

10. The system defined in claim 1 wherein at least one of 20 
the program guide resources comprises a program guide 
database access resource. 

11. The system defined in claim 1 wherein at least one of 
the program guide resources comprises a scheduling 
resource. 25 

12. The system defined in claim 1 wherein at least one of 
the program guide resources comprises a program guide 
menu resource. 

13. The system defined in claim 1 further comprising 
means for maintaining a registered application list. 



14. The system defined in claim 1 further comprising 
means for processing control requests from the program 
guide application and non-guide applications. 

15. The system defined in claim 1 further comprising 
means for directing user input to the program guide appli- 
cation and non-guide applications, 

16. The system defined in claim 1 wherein the plurality of 
device resources comprise set-top box device resources. 

17. The system defined in claim 1 further comprising 
means for coordinating multiple requests to utilize the 
device resources. 

18. The system defined in claim 1 further comprising 
means for coordinating multiple requests to utilize the 
program guide resources. 

19. The system defined in claim 1 further comprising 
means for suspending the operation of one of the applica- 
tions. 

20. The system defined in claim 1 farther comprising: 
a user input device; and 

means for resolving conflicts between applications that 
desire access to the user input device at the same time. 

21. The system defined in claim 1 further comprising: 
remote control keys for controlling the user television 

equipment; and 

means for resolving conflicts between applications that 
request access to the same remote control keys. 
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